package com.approval.mapper;

import com.approval.entity.UserRole;
import com.approval.entity.User;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 用户角色关联Mapper接口
 */
@Mapper
public interface UserRoleMapper {
    
    /**
     * 插入用户角色关联
     */
    int insert(UserRole userRole);
    
    /**
     * 根据ID删除用户角色关联
     */
    int deleteById(Long id);
    
    /**
     * 根据用户ID删除所有关联
     */
    int deleteByUserId(Long userId);
    
    /**
     * 根据角色ID删除所有关联
     */
    int deleteByRoleId(Long roleId);
    
    /**
     * 根据用户ID和角色ID删除关联
     */
    int deleteByUserIdAndRoleId(@Param("userId") Long userId, @Param("roleId") Long roleId);
    
    /**
     * 根据用户ID查询角色ID列表
     */
    List<Long> selectRoleIdsByUserId(Long userId);
    
    /**
     * 根据角色ID查询用户ID列表
     */
    List<Long> selectUserIdsByRoleId(Long roleId);
    
    /**
     * 统计角色下的用户数量
     */
    long countByRoleId(Long roleId);
    
    /**
     * 检查用户角色关联是否存在
     */
    boolean existsByUserIdAndRoleId(@Param("userId") Long userId, @Param("roleId") Long roleId);
    
    /**
     * 根据角色ID查询用户列表
     */
    List<User> selectUsersByRoleId(Long roleId);
}
